14 October 1997
In progress, posted for LG review only
First edition 1989-09-15
Cartes d'identification -- Cartes à circuit(s) integré(s) à contacts --
Partie 3: Signaux électroniques et protocoles de transmission
Reference number ISO/IEC 7816-3: 1989 (E)
© ISO/IEC 1989
All rights reserved. No part of this publication may be reproduced or utilized in any form or by any means, electronic or mechanical, including photocopying and microfilm, without permission in writing from the publisher.
ISO/IEC Copyright Office Case postale 56 CH-1211 Genève 20 Swrtzerland Printed in Switzerland
ii
ISO (the International Organization for Standardization) and IEC (the International Electrotechnical Commission) together form a system for worldwide standardization as a whole. National bodies that are members of ISO or IEC participate in the development of International Standards through technical committees established by the respective organization to deal with particular fields of technical activity. ISO and IEC technical committees coilaborate in fields of mutual interest. Other international organizations, governmental and non-governmental, in liaison with ISO and IEC, also take part in the work.
In the field of information technology, ISO and IEC have established a joint technical committee, ISO/IEC JTC1. Draft International Standards adopted by the joint technical committee are circulated to national bodies for approval before their acceptance as International Standards. They are approved in accordance with procedures requiring at least 75 % approval by the national bodies voting.
International Standard ISO/IEC 7816-3 was prepared by Joint Technical Committee ISO/IEC JTC1, Information Technology.
iii
This part of ISO/IEC 7816 is one of a series of standards describing the parameters for integrated circuit(s) cards with contacts and the use of such cards for international interchange.
These cards are identification cards intended for information exchange negociated between the outside and the integrated circuit in the card. As a result of an information exchange, the card delivers information (computation results, stored data), and/or modifies its content (data storage, event memorization).
During the preparation of this International Standard, information was gathered concerning relevant patents upon which application of this standard might depend. Relevant patents were identified in France and USA, the patent holder being Bull S.A. in each case. However, ISO cannot give authoritative or comprehensive information about evidence, validity or scope of patents or like rights.
The patent holder has stated that licences will be granted on appropriate terms to enable application of this part of ISO/IEC 7816, provided that those who seek licences agree to reciprocate.
Further information is available from:
BULL S.A.
Division de la Propriété Industrielle
25, avenue de la Grande Armée
75016 PARIS
FRANCE
iv
This part of ISO/IEC 7816 specifies the power and signal structures, and information exchange between an integrated circuit(s) card and an interface device such as a terminal.
It also covers signal rates, voltage levels, current values, parity conventions, operation procedures, transmission mechanisms and communication with the integrated circuit(s) card.
It does not cover information and instruction content, such as identification
of issuers and users, services and limits, security features, journaling
and instruction definitions.
The following standards contain provisions which, through reference in this text, constitute provisions of this part of ISO/IEC 7816.
At the time of publication, the editions indicated were valid. All standards are subject to revision, and parties to agreements based on this part of ISO/IEC 7816 are encouraged to investigate the possibility of applying the most recent editions of the standards listed below. Members of IEC and ISO maintain registers of currently valid International Standards.
ISO 1177 : 1985, Information processing -- Character structure for start/stop and synchronous character oriented transmission.
ISO 7810 : 1985, Identification cards -- Physical characteristics.
ISO 7816-1 : 1987, Identification cards -- Integrated circuit(s) cards with contacts -- Part 1 : Physical characteristics.
ISO 7816-2 : 1988, Identification cards -- Integrated circuit(s) cards
with contacts -- Part 2 : Dimensions and location of the contacts.
The term identification card is defined in ISO 7810. For the purpose of this part of ISO/IEC 7816, the following definitions apply:
Interface device : A terminal, communication device or machine to which the integrated circuit(s) card is electrically connected during operation.
State H : High state logic level .
State L : Low state logic level .
State Z : Mark (as defined in ISO 1177).
State A : Space (as defined in ISO 1177).
'XY' : Hexadecimal notation, equal to XY to the base 16.
4.1 Electrical functions
Contacts assignments are specified in ISO 7816-2, supporting at least the following electrical circuits:
I/O: Input or output for serial data to the integrated circuit inside the card.
VPP: Programming voltage input (optional use by the card) .
GND: Ground (reference voltage).
CLK: Clocking or timing signal (optional use by the card) .
RST: Either used by itself (reset signal supplied from the interface device) or in combination with an additional internal reset control circuit (optional use by the card). If internal reset is implemented, the voltage supply on VCC is mandatory.
VCC: Power supply input (optional use by the card).
NOTE -- The use of two remaining contacts will be defined in the appropriate application standards.
1
4.2 Voltage and current values
4.2.1 Measurement conventions
All measurements are defined with respect to contact GND and in an ambient temperature range of 0° C to 50° C.
All currents flowing into the card are considered positive.
All timings shall be measured relative to the appropriate threshold levels as defined in 4.2.3 to 4.2.7.
A contact is inactive when it remains between 0 V and 0,4 V referenced to contact GND for currents less than 1 mA.
4.2.2 Abbreviations
VIH | High level input voltage | IIH | High level input current |
VIL | Low level input voltage | IIL | Low level input current |
VCC | Power supply voltage at VCC | ICC | Supply current at VCC |
VPP | Programming voltage at VPP | IPP | Programming current at VPP |
VOH | High level output voltage | IOH | High level output current |
VOL | Low level output voltage | IOL | Low level output current |
tR | Rise time between 10 % and 90 % signal amplitude | CIN | Input capacitance |
tF | Fall time between 90 % and 10 % of signal amplitude | COUT | Output capacitance |
4.2.3 I/O
This contact is used as input (reception mode) or output (transmission mode) for data exchange. Two possible states exist for l/O:
-- mark or high state (state Z), if the card and the interface device are in reception mode or if this state is imposed by the transmitter:-- space or low state (state A), if this state is imposed by the transmitter.
When the two ends of the line are in reception mode, the line shall be maintained in state Z. When the two ends are in non-matched transmit mode, the logic state of the line may be indeterminate. During operation, the interface device and the card shall not both be in transmit mode.
[Sample constructed table follows; compare to graphics tables below]
Symbol |
Conditions |
Minimum |
Maximum |
Unit |
|
VIH |
Either or 1) |
I IH max = ± 500 µA |
2 |
VCC |
V |
I IH max = ± 20 µA |
0,7 x VCC |
VCC 3) |
V |
||
VIL |
I IL max = - 1 mA |
0 3) |
0,8 |
V |
|
VOH 2) |
Either or |
I OH max = - 100 µA |
2,4 |
VCC |
V |
I OH max = - 20 µA |
3,8 |
VCC |
V |
||
VOL |
I OL max = 1 mA |
0 |
0,4 |
V |
|
tR tF |
CIN = 30 pF ; COUT = 30 pF |
1 |
µs |
||
1) For the interface device, take into account both conditions. 2) It is assumed that a pull-up resistor is used in the interface device (recommended value : 20 kOmega). 3) The voltage on I/O shall remain between -0,3 V and VCC +0,3 V.
|
4.2.4 VPP
This contact may be used to supply the voltage required to program or to erase the internal non-volatile memory. Two possible states exist for VPP: idle state and active state, as defined in table 2. The idle state shall be maintained by the interface device unless the active state is required.
[Graphics tables follows]
Rise or fall time : 200 µs maximum. The rate of change of VPP shall not exceed 2 Vµs.
The maximum power VPP x IPP shall not exceed 1,5 W when averaqed over any period of 1 s.
4.2.5 CLK
The actual frequency, delivered by the interface device on CLK, is designated either by fi the initial frequency during the answer to reset, or by fs the subsequent frequency during subsequent transmission. For frequency values, see 6.1.4.4.
Duty cycle for asynchronous operation shall be between 45 % and 55 % of the period during stable operation. Care shall be taken when switching frequencies (from fi to fs) to ensure that no pulse is shorter than 45 % of the shorter period.
3
4.2.6 RST
The reset signal at RST is delivered according to subclause 5.2.
4.2.7 VCC
This contact is used to supply the power voltage VCC.
This operating procedure applies to every integrated circuit(s) card with contacts.
The dialogue between the interface device and the card shall be conducted through the consecutive operations:
-- connection and activation of the contacts by the interface device:-- reset of the card;
-- answer to reset by the card;
-- subsequent information exchange between the card and the interface device;
-- deactivation of the contacts by the interface device.
These operations are specified in the following subclauses.
NOTE--An active state on VPP should only be provided and maintained
when requested by the card.
5.1 Connection and activation of the contacts
The electrical circuits shall not be activated until the contacts are connected to the interface device so as to avoid possible damage to any card meeting these standards.
The activation of the contacts by the interface device shall consist of the consecutive operations:
-- RST is in state L;-- VCC shall be powered;
-- I/O in the interface device shall be put in reception mode;
-- VPP shall be raised to idle state;
-- CLK shall be provided with a suitable and stable clock See 4.2.5.
4
5.2 Reset of the card
A card reset is initiated by the interface device, whereupon the card shall respond with an Answer-to-Reset as described in clause 6.
By the end of the activation of the contacts (RST in state L, VCC powered and stable, I/O in reception mode in the interface device, VPP stable at idle state, CLK provided with a suitable and stable clock), the card answering asynchronously is ready for reset. See figure 1.
The clock signal is applied to CLK at time T0. The I/O line shall be set to state Z within 200 clock cycles of the clock signal (t2) being applied to CLK (time t2 after T0).
An internally reset card is reset after a few cycles of the clock signal. The Answer-to-Reset on I/O shall begin between 400 and 40 000 clock cycles (t1) after the clock signal is applied to CLK (time t1 after T0).
A card with an active low reset is reset by maintaining RST in state L for at least 40 000 clock cycles (t3) after the clock signal is applied to CLK (time t3 after T0). Thus, if no Answer-to-Reset begins within 40 000 clock cycles (t3) with RST in state L, RST is put to state H (at time T1). The Answer-to-Reset on I/O shall begin between 400 and 40 000 clock cycles (t1) after the rising edge of the signal on RST (time t1 after T1).
End of formatting and proofing -- rough scan follows
If the Answer-to-Reset does not begin within 40 000 clock cycles (t3) with RST in state H (t3 after T1), the signal on RST shall be returned to state L ~at time T2) and the contacts shall be deactivated by the interface device. See subclause 5.4.
With ù c-rd ùn~wering ~ynchronou~ly, the interface device sets all lines to state L. See figure 2. VCC is then powered, VPP is set to idle state, CLK and RST remain in state L, I/O is put in reception mode in the interface device. RST shall be maintained in state H for at least 50 lls ~tl2), before returning to state L again.
The clock pulse is applied after an interval ~tlo3 from the rising edge of the reset signal. The duration for the state H of the clock pulse can be any value betwee l0 lls and 50 lls; no more than one clock pulse during reset high is allowed. The time interval between the falling edges on CLK and RST is tl 1
The first data bit is obtained as an answer on 1/0 while CLK is in state L and is valid after an interval tl3 from the falling edge on RST.
NOTES
The intemal state of the card is assumed not to be defined before reset. Therefore the design of the card has to avoid improper operation.
2 In order to continue the dialogue with the card, RST shall be maintained in the state where an answer occurs on UO.
3 Reset of a card can be initiated by the interface device at its discretion at any time.
4 Interface devices may support one or more of these types of reset behaviour. The priority of testing for asynchronous or svnchronous cards is not defined in this standard
5.3 An~w-r-to-R~t ùnd ~ub~qu-nt inform~tion oxchlmgo
The card answers after reset with a sequence defined in clause 6.
All data exchanged over the 1/0 circuit correspond to the execuion of commands ~via RST for reset and via 1/0 for any other command).
As for Answer-to-Reset, the operating procedure of commands ~except those commands to be specified in
the next part of ISO/IEC 7816) depends on the type of transmission ~asynchronous or synchronous) and on the protocol type.
NOTES
The asynchronous half duplex character transmission protocol, with the interface device as the master, is specified in clause 8. the asynchronous half duplex block transmission protocol in ciause 9. Further protocol types between the card and the interface device are for further studv.
2 The interindustry commands for interchange are to be specified in the next part of ISO/IEC 7816. Application specific commands are specified either in existing standards or in additional standards to be defin~3t1
5.4 D- ctiv-tion of th- cont-ct
When information exchange is terminated or aborted ~unresponsive card or detection of card removal), the electrical contacts shall be deactivated.
The deactivation by the interface device shall consist of the consecutive operations:
--State L on RST; --State L on CLK; --VPP inactive; --State A on 1/0; --VCC inactiva
6 Answer-to-Reset Two types of transmission are considered Asynchronous trsnsmission
In this type of transmission, characters are transmitted on the l/O line in an asynchronous half duplex mode Each character includes an 8-bit byte. See 6.1.2.
Synchronou- transmis~ion
In this type of transmission, a series of bits is transmitted on the l/O line in half duplex mode in synchronisation with the clock signal on CLK.
6.1 Answ-r-to-Re~t in a~ynchronous transmi~sion 6.1.1 Bit duration
The nominal bit duration used on l/O is defined as one Elementary Time Unit (etu).
For cards having internal clock, the initial etu is 9 600 s
For cards using the external clock, there is a linear relationship between the Elementary Time Unit used or i/O and the period provided by the interface device on Cl K
The initial etu is f s where fj is in hertz.
See also 6.1.4.1.
The initial frequency fj is provided by the interface device on CLK during the answer to reset, as defined in 4.2.5.
In order to read the initial character ~TS~, all cards shall initially be operated with fj in the range of 1 MHz to 5 MHz.
6.1.2 Char-ct-r frame during anuwer to r~et
Prior to the transmission of a character, I/O shall be in state 7
A character consists of ten consecutive bits: a start bit in state A, eight bits of information, designated ba to bh and conveying a data byte, and a tenth bit bi used for even parity checking.
A data byte consists of 8 bits designated bl to b8, from the least significant bit (Isb, bl ) to the most significant bit (msb, b8).
Conventions (level coding, connecting levels ~A to digits 1 or 0; and bit significance, connecting ba--bh to b1--b8) are specified in the initial character, called TS, which is transmitted by the card in response to reset.
Parity is correct when the number of ONES is even in the sequence from ba to bi.
Within a character, the time from the leading edge of the start bit to the trailing eage of the nth bit shall equal (n~0,2) etu.
When searching for a start, the receiver samples l/O periodically. The time origin being the mean ~etween last observation of level Z and first observation of level A, the start shall be verified before 0,7 etu, and then ba is received at (1,5~0,2) etu, bb at (2,5~:0,2) etu, ... bi at (9,5i0,2) etu. Parity is checked on the fly.
NOTE--When searching for a start, the samciing time shall be less than 0.2 etu so that all the test zones are distinct from the transition zones.
The delay between two consecutive characters (between start leading edges) is at least 12 etu, including a character duration (10~0,2) etu plus a guardtime. While in guardtime, the interface device and the card remain both in reception, so that l/O is in state Z. See figure 3.
Start Parity Next
z bit~ 8 data bits ~ bit Start
balbb|bc|bdlbe|bllbg|b~b | Gu,r~lrr~ -- ( n ~ 0,2) etu _ n t10 Figur- 3--ChNracter frame
During the answer to reset, the delay between the start leading edges of two consecutive characters from the card shall not exceed 9 600 etu. This maximum value is named initial waiting time.
6.1.3 Error detection and character r-petition
During the answer to reset, the following character repetition procedure depends on the protocol type. See 6.1.4.3. This procedure is mandatory for cards using the protocol type T=0; it is optional for the interface device and for other cards.
The transmitter tests l/O, (11~0,2) etu after the start leading edge:
--If l/O is in state Z, the correct reception is assumed .
--If l/O is in state A, the transmission is assumed to have been incorrect. The disputed character shall be repeated after a delay of at least 2 etu after detection of the error signal.
When parity is incorrect, from (10,5~0,21 etu, the receiver transmits an error signal as state A for 1 etu minimum and 2 etu maximum. The receiver then shall expect a repetition of the disputed character. See figure 8.
If no character repetition is provided by the card,
--the card ignores and shall not suffer damage from the error signal coming from the interface device;
--the interface device shall be able to initiate the repetition of the whole Answer-to-Reset sequence.
6.1.4 Structur- ùnd content
A reset operation results in an answer from the card consisting of the initial character TS, followed by at most 32 characters in the following order:
--T0 ...............Format character .........Mandatory --TAj T8j TCj TDj ..Interface characters ......Optional --T1 T2 ..TK .......Historical characters .....Optional --TCK ..............Check character ........Conditional
See 6.1.4.1 to 6.1.4.4 and figure 4.
The interface characters specify physical parameters of the integrated circuit in the card and logical characteristics of the subseauent exchange protocol.
The historical characters designate general information, for example, the card manufacturer, the chip inserted in the card, the masked ROM in the chio, the state of the life of the card. The specification of the historical characters falls outside the scope of this part of ISO/IEC 7816.
For notational simplicity, T0 TAj... T1... TCK will designate the bytes as well as the characters in which they are ~ont~inl?d
6.1.4.1 Structur- of TS, th- initial character
The initial character TS provides a bit synchronisation sequence and defines the conventions to code data bytes in all subsequent characters. These conventions refer to ISO 1177.
1/0 is initially in state Z. A bit syncnronization sequence Q)AZZA is defined for the start bit and bits ba bb bc. See figure 5.
The 3 bits bd be bf specify inverse or direct convention, with values of AAA or ZZ, respectively.
The last 3 bits bg bh bi shall be AAZ for checking parity.
NOTE--This allows the interface device to determine the etu initially used by the card. An altemate measurement of etu is a third of the delay between the first two falling edges in TS. Transmission and reception mechanisms in the card (including the tolerances described in 6.1.2 and 6.1.3) shall be consistent with this alternate definition of etu.
The two possible values of TS (ten consecutive bits from start to bi and corresponding hexadecimal value) are
--Inverse convention: ~Z) where logic level ONE is A, ba Is W (msD Is tlrst), equal to '3F' when decoded by inverse convention.
--Direct convention: ~Z)AZZAZZZAAZ where logic level ONE is Z, ba j5 bl ~Isb is first), equal to '38' when decoded by direct convention.
6.1.42 Structure of the ~ubsequent characten in the An~w~r-to-Re~t
The initial character TS is followed by a variable number of subsequent characters in the following order: the format character T0 and, optionally, the interface characters TAj TBj TCj TDj and the historical characters T1 T2 ... TK and, conditionally, the check character TCK.
The presence of the interface characters is indicated by a bit maD technique explained below
The presence of the historical characters is indicated by the number of bytes as specified in the format character defined below.
The presence of the check character TCK-depends on the protocol type(s) as defined below.
Forrnat character T0
The T0 character contains two parts:
--The most significant half byte (b5 b6 b7 b8) is named Y1 and indicates with a logic level ONE the presence of subseauent interface characters TAl TB
TC1 TDl respectively.
--The least significant half byte (b4 to bl) is named K and indicates the number (0 to 15) of historical characters. See figure 6.
| b8 | b7 | b6 | b5 | b4 7 b3 | b2 | bl | '~ Yl ~ K
Y1 ..Indicator for the presence of interface characters TA1 is transmitted when b5=1 TB1 is transmitted when b6=1 TC1 is transmitted when b7=1. TD1 is transmitted when b8=1 K ...Number (0 to 15) of historical characters
Figur 6--Infonnation provid~d by T0 Interfac- characten TAj TBj TCj TDj
TAj TBj TCj (i = 1, 2, 3 ...) indicate the protocol parameters. TDj indicates the protocol type T, as defined in 6.1.4 3, and the presence of subsequent interface characters.
Bits b5 b6 b7 b8 of the byte containing Yj (T0 contains Yl; TDj contains Yj+1) state whether character TAj for b5, character TBj for b6, character TCj for b7, character TDj for b8 are or are not (depending on whether the relevant bit is 1 or 0) transmitted subsequently in this order after the character containing Yj.
When needed, the interface device shall attribute a default value to information corresponding to a non transmitted interface character.
When TDj is not transmitted, the cefault value of Yj+1 is null, indicating that no further interface characters TAj+
TBj+l TCj+l TDj+l will be transmitted. See figure 7
b8 I b7 I b6 I b5 I b4 I b3 I b2 I bl Yi+l Yj+1 ...Indicator for the presence of interface characters TAI+1 is transmitted when b5=1 TBj+1 is transmitted when b6=1 TCj+1 is transmitted when b7=1. TDj+1 is transmitted when b8=1. T ......Protocol type for subsequent transmission See 6.1.4 3. Figure 7--Information provided by TD
Historical characters T1 T2 ... TK
When K is not null, the Answer-to-Reset is continued by transmitting K historical characters T1 T2 ... TK
Chock character TCK
The value of TCK shall be such that the exclusive-oring of all bytes from T0 to TCK included is null.
The Answer-to-Reset is complete 1 2 etu ~fter the le3ding edge of the last character
6.1.4.3 Protocol type T
The four least significant bits of any interface byte TDj indicate a Drotocol type T, specifying rules to be used to process transmission protocols. When TD1 is not transmitted, T=0 is used.
T = O is the asynchronous half duplex character transmission protocol specified in clause 8.
T= 1 is the asynchronous half duplex block transmission protocol specified in clause 9.
T = 2 and T = 3 are reserved for future full duplex operations.
T= 4 is reserved for an enhanced asynchronous half duplex character transmission protocol.
T = 5 to T = 13 are reserved for future use.
T= 14 is reserved for protocols not standardized by ISO.
T = 15 is reserved for future extension.
TA1 TB1 TC1 and TB2 are the global interface bytes specified in 6.1.4.4. These global interface bytes shall be interpreted in order to process any transmission protocol correctlv.
The other interface bytes TAj TBj TCj are the specific interface bytes. Their interpretation aepends on the protocol type indicated by T in TDj~1
If more than three interface bytes TAj TBj TCj are defined for a specific protocol type and are to be sent in the Answer-to-Reset sequence, they shall be sent subsequently by using TD-bytes which all indicate the same Drotocol tvPe.
If more than one protocol type is indicated and T=0 is one of them, T=0 shall be indicated first.
If only T=0 is indicated, TCK shall not be sent. In all other cases, TCK shall be sent.
6.1.4.4 Specification~ of tl~ global interface byte~
Among the interface bytes possibly transmitted by the card in Answer-to-Reset, this subclause defines only the global interface bytes TA1 TB1 TCl TB2
These global interface bytes convey information to determine parameters which the interface device shall take into account.
Param~ters F, D, I, P, N
The initial etu used during Answer-to-Reset is replaced by the work etu during subsequent transmissions. F is the clock rate conversion factor and D is the bit rate adjustment factor to determine the work etu in subseouent transmissions.
For internal clock cards:
Initial etu = 9 600 s Work etu = D x 9 600 s
For external clock cards:
Initial etu = f s Work etu = D x f s
where fj and f~ in hertz are defined in 4.2.5.
The minimum value of fs shall be 1 MHz. The maximum value of f~, is given by table 6.
I and P define the active state at VPP. --Maximum programming current: Ipp = I mA. --Proqramming voltage: Vpp = P V.
N is an extra guardtime requested by the card. Before receiving the next character, the card requires a delay of at least (12+N~ etu from the start leading edge of the previous character. No extra guardtime is used to send characters from the card to the interface device.
The default values of these parameters are
F = 372: D = 1; 1 = 50; P = 5; N = 0.
These parameters are described in greater detail at the end of this subclause under Integer Values to Parameters Correspondence.
Int~ger vsluff in the global int~rface byt~
The global interface bytes TA1 TB1 TC1 TB2 code integer values Fl, Dl, Il, Pl1, N, Pl2 which are either equal to or used to compute the values of the parameters F, D, I, P, N presented above.
TA~ codes Fl over the most significant half byte ~b8 to b5), and Dl over the least significant half byte (b4 to b1). See tables 6 and 7.
TB1 codes ll over the bits b7 and b6, and Pl1 over the 5 least significant bits b5 to b1. See table 8. The most significant bit b8 equals 0.
NOTE--The interface device may ignore the bit b8 of TBl.
TC1 codes N over the eight bits (b8 to b1).
TB2 codes Pl2 over the eight bits (b8 to b1).
All undefined values of the following parameters are reserved for future use by ISO/IEC JTC1/SC17.
Integor valu~ to parameten corr~pond nc
The correspondence between the parameters F, D, I, P, N and the integer values Fl, Dl, Il, Pl1, N, Pl2 is given below.
T-bl- 6--Clock rata conv~ruon factor F
Fl 0000 0001 0010 0011 0100 0101 0110 0111 F Internal Clock 372 558 744 1116 1488 1860 RFU fs (max) MHz -- 5 6 8 12 16 20 RFU = Reserved for Future Use Fl 1000 1001 1010 1011 ~ _ 1111 F RFU 512 768 1024 1536 2048 RFU RFU f~, (max) MHz -- 5 7,5 1 0 15 20
I:~v/lc ~ a:~ ~c)
Table 7--Bit rate adjustm~nt factor D
Dl | 0000 | 0001 | 0010 | 0011 | 0100 | 0101 | 0110 | 0111 D | RFU | 1 | 2 | 4 | 8 | 16 | RFU | RFU Dl | 1000 | 1001 | 1010 | 1011 | 1100 | 11 | l110 | 1111 D RFU | RFU | 1/2 | 1/4 | 1/8 1/16 | 1/32 | 1/64
Programming voltago tactor P
Pl1 from 5 to 25 gives the value of P in volts. Pl1=0 indicates that VPP is not connected in the card which generates an internal programming voltage from VCC. Other values of Pl1 are reserved for future use.
When Pl2 is present, the indication of Pl 1 should be ignored. Pl2 from 50 to 250 gives the value of P in 0,1 V. Other values of Pl2 are reserved for future use.
Tablo 8--Maximum programming cu~ont factor I 1 11 ~ 00 1 01 1 10 1 11 I 25 T 50 | 100 | Extra guardtime N
N codes directly the extra guardtime, from 0 to 254 etu. N=255 indicates that the mlnimum delay between the start leading edges of two consecutive characters is reduced to 11 etu.
62 Answar-to-Ro~t in synchronous transmission 6.2.1 Uock froquoncy and bit rata
There is a linear relationship between the bit rate on the 1/0 line and the clock frequency provided by the interface device on CLK
Any clock frequency between 7 kHz and 50 kHz may be chosen for the reset sequence. A clock frequency of 7 kHz corresponds to 7 kbit/s, and values of the clock frequency up to 50 kHz cause corresponding bit rates to be transmitted .
62.2 Structura of tho hoador of Answar-to-R~t
The reset operation results in an answer from the card containing a header transmitted from the card to the interface. The header has a fixed length of 32 bits and beains with two mandatorv fields of 8 bits. H1 and H2
The chronological order of transmission of the information bits shall correspond to bit identification b1 to b32 with the least significant bit transmitted first. The numerical meaning corresponding to each information bit considered in isolation is that of the digit
--O for a unit corresponding to state A (space);
--1 for a unit corresponding to state Z (mark).
6.2.3 Timing of the header
After the reset procedure, see 5.2 and figure 2, the output information is controlled by clock pulses. The first clock pulse is applied between 101ls and 100~1s (t14) afterthe falling edge on RST to read the data bits from the card. State H of clock pulses can be varied between 10 ~s and 50 lls (t1 s) and state L between l 0 lls and 100 lls (t16).
The first data bit is obtained on l/O while the clock is low and is valid 10~1s (t13) at least after the falling edge on RST. The following data bits are valid 10 ~lS (t17) at least after the falling edge on CLK. Each data bit is valid until the next falling edge of the following clock pulse on CLK. The data bits can therefore be sampled at the rising edge of the following clock pulses.
62.4 Data content of tho hoad~r
The header allows a quick determination of whether the card and the interface device are compatible. If there is no compatibility, the contacts shall be deactivated according to subclause 5.4.
The first field H1 codes the protocol type. The values of the codes and the corresponding protocol types are
Hexadecimal value Protocol type
'00' and 'FF' ........not to be used '01' to 'FE' .........each value is assigned by ISO/IEC JTC1tSC17 to one protocol type.
The second field H2 codes parameters for the protocol type coded in field H 1. The values of H2 are to be assigned by ISO/IEC JTC1/SC17.
The specifications of the remaining fields fall outside the scope of this part of ISO/IEC 7816. The role of these remaining fields is similar to that of the historical characters mentioned in 6.1.4.
7 Protocol type selection (PTS)
If only one protocol type and Fl=D=1 (default value of rA1~ and N smaller than 255 is indicated in the Answer-toReset, the transmission protocol associated to the protocol type may be started immediately after the transmission of the Answer-to-Reset.
If more than one protocol type and/or TA1 parameter ~alues other than the default values and/or N equal to 255 is/are indicated in the Answer-to-Reset, the card shall know unambiguously, after having sent the Answer-toReset, which protocol type and/or transmission parameter values (Fl, D, N) will be used. Consequently a selection of the protocol type and/or the transmission parameter values shall be specified.
If the card is able to process more than one protocol type and if one of those protocol types is indicated as T=0 then the protocol type T=0 shall be indicated in TD1 as the first offered protocol, and is assumed if no PTS is Derformed
If a card offers more than one protocol and if the interface device supports only one of these protocols which is not T=0 and does not suDpon PTS, the interface device should reject or reset the card.
7.1 PTS protocol
Only the interface device is permitted to start the PTS procedure:
--The interface device sends a PTS request to the card.
-- If the card receives a correct PTS request, it answers by sending a PTS confirm, if implemented, or the initial waiting time will be exceeded.
--After the successful exchange of PTS request and PTS confirm, data shall be transmitted from the interface device to the card using the selected protocol type and/or transmission parameters.
--If the card receives an erroneous PTS request, it will not send a PTS confirm
--If the initial waiting time is exceeded, the interface device should reset or reject the card.
--If the interface device receives an erroneous PTS confirm, it should reset or reject the card.
rhe parameters for the transmission of the PTS request and PTS confirm shall correspond to those used within the Answer-to-Reset regarding the bit rate and the convention detected by TS and possibly modified by TC
(extra guardtime).
7.2 Structure and content of PTS request and PTS rnnfirm
The PTS request and PTS response each consist of one initial character PTSS, followed by a format character PTS0, three optional parameter characters PTS1 PTS2 PTS3, and a character check PCK as the last byte.
PTSS identifies the PTS request or PTS confirm and is coded 'FF' .
PTS0 indicates by the bits b5, b6, b7 set to 1 the presence of the subsequently sent optional characters PTS1, PTS2, PTS3, respectively. It codes over the least significant bits b4 to b1 the selected protocol type T as coded in TDbytes. The most significant bit b8 (default: b8=0) is ra.~ArvPr~ f~lr fl Itl IrP I ICP
PTS1 codes the parameter values Fl and D as coded in TA1. The interface device may send PTS1 in order to indicate the selected Fl and/or D values to the card. If PTS1 is not sent, Fl=1 and D=1 are assumed as defaults. The card either acknowledges both the Fl and D values by echoing PTS1 or does not send PTS1 indicating the use of the default values.
PTS2 indicates the support of N=255, when bit bl is set to 1. Bit bl set to 0 is the default ana indicates that the 11etu period is not used. If bit b2 is set to 1, the card shall use an extra guardtime of 12 etu for its transmission of characters to the interface device Bit b2 set to 0 is the default and indicates that no extra guardtime is required. Bits b3 to b8 are reserved for future use.
If PTS2 is sent by the interface device and is not echoed by the card, the interface device should reject or reset the card .
The coding and use of PTS3 is to be defined.
The value of PCK shall be such that the exclusive-oring of all characters from PTSS to PCK included is null.
8 Protocol type T=0, asynchronous half duplex character transmission protocol
This clause defines the structure and processing of commands initiated by an interface device for transmission control and for card specific control in an asynchronous half duplex character transmission protocol .
This protocol uses the parameters indicated by the Answer-to-Reset, unless modified by protocol type selection.
Interindustry commands for international interchange will be defined in the next part of ISOtlEC 7816.
8.1 Sp c;fic intorfoco pcrAmotor . th- work waiting tim
ln the Answer-to-Reset, the interface character TC2 codes the integer value Wl over eight bits b8 to b1. When no TC2 appears in the Answer-to-Reset, the default value of Wl is
The interval between the start leading edge of any character sent by the card and the start leading edge of the previous character Isent either by the card or by the interface device) shall not exceed 960 x D x Wl work etu. This maximum delay is named the work waitina time.
8.2 Structur- ùnd proc~ing of command~
A command is always initiated by the interface device. It tells the card what to do in a 5-byte header, and allows a transfer of data bytes under control of procedure bytes sent by the card.
It is assumed that the card and the interface device know a priori the direction of data, in order to distinguish between instructions for incoming data transfers (where data enter the card during execution) and instructions for outgoing data transfers (where data leave the card during execution).
During transmission by the card or the interface device, the error detection and character repetition procedure described in 6.1.3 is mandator,v. See figure 8.
8.2.1 Command h-~dor ~nt by the interface device
The interface device transmits a header over five successive bytes designated CLA, INS, P1, P2, P3.
--CLA is an instruction class. The value 'FF' is reserved for PTS. See clause 7.
--INS is an instruction code in the instruction class. The instruction code is valid only if the least significant bit is 0, and the most significant half byte is neither'6' nor'9'.
a~ Without parity error Stan b)- With parity error st.rt Byte Bytej Figur- 8--Byt tro
--P1 P2 are a reference (e.g. an aadress) completing the instruction code.
--P3 codes the number n of da-a bytes (Dl...Dn) which are to be transmitted during tne command. The direction of movement of these data is a function of the instruction. In an outgoing data transfer command, P3=0 introduces a 256-byte data transfer from the card. In an ingoing data transfer command, P3=0 introduces no transfer of data.
All remaining encoding possibilities for the header are specified in subsequent parts of ISO/IEC 7816.
After transmission of such a 5-byte header, the interface device waits for a orocedure bvte.
82.2 Proc~dure byte~ ~nt by thc c~rd
The values of the procedure bytes shall indicate the action requested by the interface device. Three types of procedure bytes are specified:
--ACK (the seven most significant bits in an ACK byte are all equal or all complementary to those in the INS byte, apart from the values '6X' and '9X'). The interface device controls VPP state and exchanges data depending on ACK values
--NULL (= '60'). This byte is sent by the card to restart the work waiting time, and to anticipate a subsequent procedure byte It requests no further actif~n n~ith~r on VPP nor on data.
--SW1 (= '6X' or '9X', except '60'). The interface device maintains or sets VPP at idle and waits for a SW2 byte to complete the command.
Any transition of VPP state (active/idle) must occur within the guardtime of the procedure byte, or on the work waiting time overflow
At each procedure byte, the card can proceed with the command by an ACK or NULL byte, or show its disapproval by becoming unresponsive, or conclude by an end sequence SW1-SW2. See table 9.
Gua--n~r ~ Even parity bit Err Sigrla ~mi~ion diagram Byte j+l Repetition Bytej
ISO/IEC 7816-3: 1989 ~E) Tab~o 9--Proc~dur- byt~
B~te Valu- Result INS VPP is idle. All remaining data bytes are transferred subsequently. INS + 1 VPP is active. All remaining data bytes are transferred subsequently. INS VPP is idle. Next data byte is transferred subsequently. INS + 1 VPP is active. Next data byte is transferred subsequently. NULL '60' No further action on VPP. The interface device waits for a new procedure byte. SW1 SW1 VPP is idle. The interface device waits for a SW2 byte.
8.2.2.1 Acknowledge byt-s
The ACK bytes are used to control VPP state and data transfer.
--When exclusive-oring the ACK byte with the INS byte gives '00' or 'FF', the interface device maintains or sets VPP at idle.
--When exclusive-oring the ACK byte with the INS byte gives '01' or 'FE', the interface device maintains or sets VPP at active.
--When the seven most significant bits in the ACK byte have the same value as those in the INS byte, all remaining data bytes (Dj...Dn), if any remain, are transferred subsequently.
--When the seven most significant bits in the ACK byte are complementary to those in the INS byte, only the next data byte (Dj), if one remains, is tran.sfPrrP~i
After these actions, the interface device waits for a new procedure byte.
8.2.2.2 Null byte ~= '60')
This byte is sent by the card to reset the work waiting bme and to anticipate a subsequent procedure byte.
8.2.2.3 St~b~ b~ SW1 = '6X' or '9X', exc pt '60'; SW2 = ny volu-1
The end sequence SW1-SW2 gives the card status at the end of the command
The normal ending is indicated by SW1-SW2 = '90'-'00'.
When the most significant half byte of SW1 is '6', the meaning of SW1 is independent of the application. The following five values are defined:
'6E' The card does not support the instruction class.
1 4
'6D' The instruction code is not programmed or is invalid. '6B' The reference is incorrect.
'67' The length is incorrect. '6F' No precise diaanosis is aiven.
~ther values are reserved for future use by ISO/IEC JTC1/SC1 7.
When SW1 is neither '6E' nor '6D', the card supports the in~tnl~ti~n
This part of ISO/IEC 7816 interprets neither '9X' SW1 bytes, nor SW2 bytes; their meaning relates to the application itself
9 Protocol type T=1, asynchronous h~lf duplex block transmission protocol
This transmission protocol is defined as the protocol type T=1 in a TDj-byte of the Answer-to-Reset.
This clause defines the structure and processing of commands for transmission control and for card specific control in an asynchronous half duplex block transmission protocol. These commands are initiated either by the interface device or by the card.
This protocol uses the physical parameters and the character frame defined by the global interface characters .
This clause covers the frame structure of a block and the orqanisation of
--data transmission control such as block chaining and error correction,
--specific interface control.
The specification of this protocol is under study and will be included in this clause when availahle
UDC 35i1.755.62 ~ 3-049.77
Descriptors: data processing, idemity cards, intearated circuits, data transmission, communication procedure.
Price based on 14 pages
End rough scan of intitial section of Part 3
Other rough scan material:
Amendment 1, 13 pages;
Amendment 2, 8 pages;
7Part 4, 46 pages